Press n or j to go to the next uncovered block, b, p or k for the previous block.
| 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 | import { appGetLayout } from "components/AppRoute";
import CommunityPageComponent from "features/communities/CommunityPage";
import NotFoundPage from "features/NotFoundPage";
import { COMMUNITIES, GLOBAL, NOTIFICATIONS } from "i18n/namespaces";
import { GetStaticPaths, GetStaticProps } from "next";
import { useRouter } from "next/router";
import nextI18nextConfig from "next-i18next.config";
import { serverSideTranslations } from "next-i18next/serverSideTranslations";
import { communityTabs } from "routes";
import stringOrFirstString from "utils/stringOrFirstString";
export const getStaticPaths: GetStaticPaths = () => ({
paths: [],
fallback: "blocking",
});
export const getStaticProps: GetStaticProps = async ({ locale }) => ({
props: {
...(await serverSideTranslations(
locale ?? "en",
[GLOBAL, COMMUNITIES, NOTIFICATIONS],
nextI18nextConfig,
)),
},
});
export default function CommunityPage() {
const router = useRouter();
const parsedId = Number.parseInt(stringOrFirstString(router.query.id) ?? "");
Iif (isNaN(parsedId)) return <NotFoundPage />;
//first element of params is the tab
const tab = stringOrFirstString(router.query.params);
let parsedTab = undefined;
Iif (tab) {
//if the tab isn't blank and isn't valid, 404
parsedTab = communityTabs.find((valid) => tab === valid);
Iif (!parsedTab) return <NotFoundPage />;
}
const edit = router.query.params?.[1] === "edit";
return (
<CommunityPageComponent
communityId={parsedId}
tab={parsedTab}
edit={edit}
/>
);
}
CommunityPage.getLayout = appGetLayout();
|